草庐IT

asp.net - 防止意外双击按钮

全部标签

ruby - 如何测试 capybara 中是否存在提交按钮?

我想在rspec中测试是否存在提交按钮。我也在用capybara。我试过:shouldhave_tag("input","Submitbutton")和shouldhave_content("Submit,button")但它要么引发异常,要么给出误报。 最佳答案 这些都是很好的建议,但是如果你想确认它是一个按钮并且它有正确的值(用于显示),你必须更详细一点:page.shouldhave_selector("input[type=submit][value='PressMe']")我不知道现有的匹配器可以做到这一点。这是我编写的自

ruby-on-rails - 如何在 Ruby 2 中为 Net::HTTP::Post.new 请求指定读取超时

我有一个帖子发生在一个ruby​​脚本的rails应用程序上。该脚本创建一个变量请求作为request=Net::HTTP::Post.new(url.path)然后按如下方式使用request.content_type="application/json"request.body=JSON.generate(params)response=Net::HTTP.start(url.host,url.port){|http|http.request(request)}服务器端发生了相当多的处理,我收到了一个Net::ReadTimeout错误我尝试指定超时时间request.read_t

ruby - 是否有比 Net::HTTP 更用户友好的替代方案来与 REST API 交互?

Net::HTTP对于标准用例来说可能相当麻烦! 最佳答案 如果你只需要处理REST,rest-client图书馆很棒。如果您使用的API不是完全RESTful-或者即使它们是-HTTParty真的很值得一试。它简化了RESTAPI以及非RESTfulWebAPI的使用。查看此代码(从上面的链接复制):require'rubygems'require'httparty'classRepresentativeincludeHTTPartyformat:xmldefself.find_by_zip(zip)get('http://who

ruby-on-rails - 使用 net/http 发送 Post 请求

我需要将JSON格式的数据发送到在同一台计算机上运行的另一个应用程序。我这样发送请求(rails3.2.13)data={//somedatahash}url=URI.parse('http://localhost:6379/api/plans')resp,data=Net::HTTP.post_form(url,data.to_JSON)presppdata{resp:resp,data:data.to_JSON}但我得到Net::HTTPBadResponse(错误的状态行:“-ERR未知命令‘POST’”):我怎么解决这个问题?更新1按照@Raja-d的建议更新了我的代码url=

ruby - Capistrano 错误 - Net::SSH::HostKeyMismatch

我是Capistrano和Ruby的新手,我似乎无法设置基本的部署。每次运行capdeploy:check我都会收到以下错误:servers:["domain.com"]connectionfailedfor:me@domain.com(Net::SSH::HostKeyMismatch:fingerprint0c:de:d4:1b:e9:64:83:3a:8b:d7:c3:42:98:5b:5d:8cdoesnotmatchfor"[domain.com]:22,[62.39.11.2]:22")我的deploy.db看起来像这样:set:stages,%w(productionst

ruby-on-rails - Rails 4 俄罗斯套娃缓存如何防止踩踏?

我正在查找有关Rails4中的缓存机制如何防止多个用户同时尝试重新生成缓存键(也称为缓存踩踏)的信息:http://en.wikipedia.org/wiki/Cache_stampede我无法通过谷歌搜索找到很多信息。如果我查看其他系统(例如Drupal),缓存踩踏预防是通过数据库中的semaphores表实现的。 最佳答案 Rails没有内置机制来防止缓存踩踏。根据atomic_mem_cache_store的自述文件(替代ActiveSupport::Cache::MemCacheStore以减轻缓存踩踏):Rails(and

ruby - Net::ReadTimeout (Net::ReadTimeout) Selenium ruby

我看过一些与Selenium中的超时错误相关的帖子。这变得越来越难以忍受,因为它使我的测试包无法使用。我正在测试当前正在开发中的网页。我有一个包含大约300个测试场景的回归套件,在firefox和seleniumwebdriver的最新更新之前一直有效。现在对于我得到的几乎所有其他测试:Net::ReadTimeout(Net::ReadTimeout)错误。这不是巧合。有谁知道可能导致突然超时问题的原因是什么?我试过回到以前版本的webdriver和firefox。 最佳答案 使用的另一个选项RSpec::Retry它为间歇性失败

ruby - Ruby 的 'open-uri' 和 'Net:HTTP' gem 有什么区别?

看起来这两个gem执行的任务非常相似。任何人都可以举例说明一种gem在哪些方面比另一种更有用吗?我没有我所指的具体代码,我更想知道每个gem的一般用例。我知道这是一个简短的问题,我会根据要求填空。谢谢。 最佳答案 它们看起来执行相似任务的原因是OpenURI是Net::HTTP、Net::HTTPS和Net::FTP的包装器。通常,除非您觉得需要较低级别的接口(interface),否则使用OpenURI会更好,因为您可以使用更少的代码。使用OpenURI,您可以打开URL/URI并将其视为文件。参见:http://www.ruby

ruby - 为什么我的 BigDecimal 对象初始化时出现意外舍入错误?

在Ruby2.2.0中,为什么:BigDecimal.new(34.13985572755337,9)等于34.0但是BigDecimal.new(34.13985572755338,9)等于34.1398557?请注意,我在64位机器上运行它。 最佳答案 用字符串而不是float初始化一般来说,您无法通过float获得可靠的行为。您错误地使用Float值而不是String值初始化BigDecimals,这在一开始就引入了一些不精确性。例如,在我的64位系统上:float1=34.13985572755337float2=34.13

ruby - 通过 Net::HTTP 在 Ruby 中发送 http post 请求

我正在向Web服务发送带有自定义header的请求。require'uri'require'net/http'uri=URI("https://api.site.com/api.dll")https=Net::HTTP.new(uri.host,uri.port)https.use_ssl=trueheaders={'HEADER1'=>"VALUE1",'HEADER2'=>"HEADER2"}response=https.post(uri.path,headers)putsresponse它不工作,我收到一个错误:/usr/lib/ruby/1.9.1/net/http.rb:19